\ 

a communications driver executed by the processing unit, the communications driver 
comprising a UART emulation which\n response to an access targeted at a register set of a 
UART corresponding to the first communication port, converts the access as required for the 
register set and address assignment of the\device. 



The system of claim 1, wherein the local bus comprises an ISA bus. 



3. The system of claim 1, wherein the device coupled to the local bus, further 
comprises: ^ 

a comparator adapted for receiving a data signal from the local bus; 
a pattern generator coupled to the comparator, wherein the pattern generator generates 



a signal for comparison with the data signal 

a counter operably coupled to the comparator, wherein the counter resets to an initial 
state following the comparator indicating the data^ signal is not equal to the pattern signal and 
advances toward a final state following the comparator indicating the data signal equals the 
pattern signal; and 

a register coupled to the counter and adapted to receive a signal from the local bus, 
wherein in response to the counter reaching the final state, the register latches from the local 
bus a value which indicates the base address of the I/O slot occupied by the device. 



4. A method for communicating between *a computer and a device having an I/O 
interface which differs from the I/O interface of a UART, comprising: 

coupling the I/O interface of the device to a loc Jl bus in the computer; 

allocating in a memory of the computer, storage locations which correspond to 
registers of a UART; 

transmitting a packet formatted for a UART via ^communications driver including a 
UART emulation; 

updating a value in the storage locations according to a value in the packet via the 
UART emulation; and 
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transmitting information via the local bus between the I/O interface of the device and 
the allocated storage locations in the memory of the computer. 



6. The method of claim 4 wherein an I/O handler performs the step of said 
transmitting information by: \ 

converting a value from the allocated storage to a converted value compatible with the 
I/O interface of the device; and 1 

writing the converted value to a register in the device via the local bus. 



7. The method of claim 4, \ wherein said transmitting information further 
comprises: 

reading values from a registerW the device via the local bus; and 
updating the storage locations According to the value read. 



8. The method of claim 7, farther comprising transmitting from a 
communications driver to an application information from the storage locations. 



9. The method of claim 4, further comprising: 

executing on the computer an operating environment which allocates I/O slots on the 
local bus for UARTs; and \ 

setting a base device address for the device to correspond to one of the I/O slots 
allocated by the operating environment for the UART, 



10. The method of claim 9, wherein setting the base device address comprises: 

sensing, by the device, of a data signal on the local bus; 

comparing the data signal to a signal from a pattern generator in the device; 
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advancing a state indicator toyard a final state in response to the data signal being 
equal to the signal from the pattern generator; 

repeating the steps of sensing} comparing, and advancing until the state indicator 
reaches the final state; and 

setting the base address of the device to a value indicated by a signal on the local bus 
in response to the state indicator reaching the final state. 



17. A host signal processing modem comprising 



a device adapted for connection 



:o a local bus of a host computer, wherein the device 



occupies an I/O slot on the local bus and is accessible at a first set of addresses, the device 
having a register set with an address assignment in the first set of addresses that differs from a 
standard address assignment of a register set for a UART corresponding to the I/O slot; and 

a communications driver executable by the host computer, the communication driver 
comprising a UART emulation, wherein in response to the host computer executing a 
procedure that targets an access at a register set of a UART, the UART emulation converts the 
access as required for accessing the registerlset and address assignment of the device. 



18. The modem of claim 17, wherein the procedure that targets an access at the 
register set of a UART is part of an operating^system that the host computer executes. 



19. A communication driver executable by a host computer running an operating 
system that assigns a first port to a UART, the communication driver comprising: 

a UART emulation that in response to a procedure requesting access to a register of a 
UART at a first port, instead accesses storage locations in a memory of the host computer; 
and ^ 

an I/O handler that transfers values between the storage locations and a register set of 
a non-standard device having an address assignment that differs from that of a UART, 
wherein the register set of the non-standard deyice physically occupies addresses 
corresponding to the first port. 
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21. The communication driver of claim 19, further comprising modem software 
that implements a conversion between data and digital samples representing a signal in 
accordance with a communication protocol. 



22. The communication driver of claim 19 wherein the address of a first storage 



location corresponds to a line contn 
corresponds to a line status register 



1 register, the address of and a second storage location 



23. The host signal processing modem of claim 17 wherein the register set 
includes a line control register, a line status register and a modem control register. 



60309368-1 



24. (Amended) A communication driver executable by a host computer running 
under an operating system , the comm jnication driver comprising a software modem operable 
to allow a device with a non-standa*d input/output interface to transparently communicate 



through the operating system with an application executing on the host computer . 



25. The communication diiver of claim 24, further comprising software that 
accesses storage locations in a memorv of the host computer in response to a call requesting 
access to a register of a hardware UAR' 



26. The communication 
between data and digital samples of wa\ 



driver of claim 25, wherein the software modem converts 
eforms in accordance with a modem protocol. 



27. The communication driver of claim 26, further comprising an I/O handler that 
transfers values between storage locations in the memory of the host computer and a register 
set of a non-UART chip in a peripheral d&vice of a host computer. 

28. The communication driverlof claim 27, wherein the peripheral device further 
comprises an analog-to-digital converter ar^d a digital-to-analog converter. 

30. A system comprising: 

a device comprising an analog to digital converter couplable to a communication 
medium to receive therefrom an analog communications signal; and 

a computer comprising a processing unit coupled to the device, to receive therefrom a 
plurality of sampled digital values, the processing unit being programmed with a software 
modem to determine data received, based on a waveform represented by the sample digital 
values, wherein the processing unit is programmed with an operating system for supporting a 
plurality of applications, at least one of the applications communicating with the software 
modem in the same manner as with a hardware mpdem. 
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3 1 . The system of Claim 30 wherein: 
the device generates interrupts; and 

the software moaem reads a set of sampled digital values from the analog to digital 
converter in response to an interrupt. 

32. The system of Claim 30 wherein: 

the device further comprises a digital to analog converter coupled to the 
communication medium ta transmit thereto an analog signal; and 

the software modem generates a series of digital values sent to the digital to analog 
converter for transmission \as an analog signal on the communication medium, the analog 
signal providing a carrier signal and data values formatted according to a standard modem 
protocol. \ 

33. (Amended) A method comprising: 

converting an analog communications signal received from a [communication 
medium] device with a non-standard input/output interface into a series of sampled digital 
values, wherein said act of converting is performed in an analog to digital converter; 

determining data received Vbased on a waveform represented by the sampled digital 
values, and based on a modem Yprotocol, wherein said determining is performed in a 
processing unit coupled to the analog to digital converter by a local bus of a computer, the 
processing unit running under an \ operating system, the sampled digital values being 
transferred from the analog to digital converter to the processing unit by the local bus; and 

providing the received data [Received to an] through the operating system to an 
a pplication executing on the processing unit, thereby allowing the device with the non- 
standard input/output interface to transparently communicate with the application . 



34. The method of Claim 33, wherein: 




60309368-1 



standard UART, and the m< 



the analog to digita converter is a portion of a device that does not comprise a 



:hod further comprises the processing unit determining if a non- 



standard UART device is present. 

35. The method of Claim 33 further comprising: 

generating a series of digital values, in said processing unit; and 

transmitting an analog signal based on the series of digital values, in a digital to analog 

converter, wherein said digital \ to analog converter is coupled to the processing unit by the 

bus. 



38. A computer comprising: 

a processing unit and memory programmed with a driver, said driver comprising (a) a 
software UART coupled to an operating system, (b) a software modem coupled to the 
software UART, and (c) an VO handler coupled to the software modem; and 

a device that does not comprise a UART, the device being coupled to the processing 
unit by a local bus, wherein the device comprises an analog to digital converter that generates 
sample digital values, and the devic^ transfers the sampled digital values via the local bus to 
the software modem. 



39. The computer of Claim 68 wherein said device is hereinafter "first device" and 
said driver is hereinafter "first driver", tne computer further comprising 

a second device comprising a\UART, the second device being coupled to the 
processing unit by the local bus; and 

a second driver comprising routined for accessing the second device. 
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40. The computer of Claim 39 wherein: 
said first device is coupldd to an I/O slot corresponding to a first COM port; and 
said second device is cou )led to an I/O slot corresponding to a second COM port. 



4 1 . The computer of Claim 40 wherein 



said first device occupies 



up to eight addresses on the local bus; and 



said second device occupies eight addresses on the local bus. 

42. The computer of Claim 38 wherein: 
the memory is further programmed with routines for accessing another device that 
comprises a UART. 



43. (Amended) A computer comprising: 

an analog to digital converter couplable to a [communication mediuml device with a 
non-standard input/output interface to receive therefrom an analog communications signal and 
coupled to a local bus to transmit thereto a series of sampled digital values; and 

a processor coupled to the lJjcal bus fandl , the processor running under an operating 
system and programmed to: 

determine data received based on a waveform represented by the sampled 
digital values and based on a modem protocol; and 

provide the received data [received to an] through the operating system of the 
computer to an application executing on the processor, thereby allowing the device with the 
non-standard input/output interface to transparently communicate with the application . 
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44. The computer of Claim 43 wherein: 

said processor is programmed to transmit a series of digital values on the local bus; 
and 1 

the computer further comprises a digital to analog converter coupled to the local bus to 
receive therefrom the series of digital values and couplable to the communication medium to 
transmit thereto an analog signal based on the series of digital values. 

45. The computer of Glaim 44, wherein: 

the analog to digital converter and the digital to analog converter are portions of a first 
device that does not comprise a standard UART; 

the computer further comprises a second device that comprises a standard UART; and 
said processor is programmer to: 

access the first devicelthrough the operating system and a software UART; and 
access the second dewce through the operating system and a standard COM 
driver. \ 
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